#pragma once
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <stdbool.h>

typedef int QType;

typedef struct QueueNode
{
	struct Queue* next;
	QType data;
}QNode;

typedef struct Queue
{
	QNode* tail;
	QNode* head;
	int size;
}Queue;

void QInit(Queue* pq);
void QDestroy(Queue* pq);

void QPush(Queue* pq, QType x);
void QPop(Queue* pq);

QType QHead(Queue* pq);
QType QTail(Queue* pq);

bool QEmpty(Queue* pq);
int QSize(Queue* pq);